treeview: Check the selected node active flag before maybe starting rubberband
authorCarlos Garnacho <carlosg@gnome.org>
Mon, 11 Aug 2014 16:02:12 +0000 (18:02 +0200)
committerCarlos Garnacho <carlosg@gnome.org>
Mon, 11 Aug 2014 16:09:16 +0000 (18:09 +0200)
This check used to be present in the pre-gestures code, but was unintentionally
removed when splitting code into drag/multiclick gestures. The policy used to
be that if clicking happened on an already selected node, DnD would happen
instead of rubberband selection, so this behavior is resuscitated.

https://bugzilla.gnome.org/show_bug.cgi?id=734143

gtk/gtktreeview.c

index 76a290d01d15c8ff2f770a7cf21fa91ed85ca0da..e7b60d9c6b5c897c58f3af2a76b57680ab8d11dd 100644 (file)
@@ -3328,13 +3328,18 @@ gtk_tree_view_drag_gesture_begin (GtkGestureDrag *gesture,
                                   GtkTreeView    *tree_view)
 {
   gint bin_x, bin_y;
+  GtkRBTree *tree;
+  GtkRBNode *node;
 
   gtk_tree_view_convert_widget_to_bin_window_coords (tree_view, start_x, start_y,
                                                      &bin_x, &bin_y);
   tree_view->priv->press_start_x = tree_view->priv->rubber_band_x = bin_x;
   tree_view->priv->press_start_y = tree_view->priv->rubber_band_y = bin_y;
+  _gtk_rbtree_find_offset (tree_view->priv->tree, bin_y + tree_view->priv->dy,
+                           &tree, &node);
 
   if (tree_view->priv->rubber_banding_enable
+      && !GTK_RBNODE_FLAG_SET (node, GTK_RBNODE_IS_SELECTED)
       && gtk_tree_selection_get_mode (tree_view->priv->selection) == GTK_SELECTION_MULTIPLE)
     {
       gboolean modify, extend;